없는 숫자 더하기
문제 설명
0부터 9까지의 숫자 중 일부가 들어있는 정수 배열 numbers
가 매개변수로 주어집니다.
numbers
에서 찾을 수 없는 0부터 9까지의 숫자를 모두 찾아 더한 수를 return 하도록 solution 함수를 완성해주세요.
제한사항
- 1 ≤
numbers
의 길이 ≤ 9- 0 ≤
numbers
의 모든 원소 ≤ 9 numbers
의 모든 원소는 서로 다릅니다.
- 0 ≤
입출력 예
numbers | result |
---|---|
[1,2,3,4,6,7,8,0] | 14 |
[5,8,4,0,6,7,9] | 6 |
입출력 예 설명
입출력 예 #1
- 5, 9가
numbers
에 없으므로, 5 + 9 = 14를 return 해야 합니다.
입출력 예 #2
- 1, 2, 3이
numbers
에 없으므로, 1 + 2 + 3 = 6을 return 해야 합니다.
풀이
첫 번째 풀이
def solution(numbers):
count = [0] * 10
for number in numbers:
count[number] += 1
sum = 0
for i in range(10):
if count[i] == 0:
sum += i
return sum
10개짜리 사이즈의 빈 리스트를 생성합니다.
그리고 numbers
배열에서 하나씩 꺼내서 꺼낸 숫자를 count
배열에서 셉니다.
예를 들어서,
numbers = [1, 2, 3]
이라고 한다면
count[1]
, count[2]
, count[3]
은 각각 1이 되지만
count[0]
과 count[4]
부터 count[9]
까지는 모두 0이 됩니다.
전부 세준 후, count[i]
가 1이면 numbers
배열에 있는 숫자고, 0이라면 없는 숫자이므로
없는 숫자를 sum
변수에 누적해주는 방식으로 풀었습니다.